<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script type="text/javascript">
        //声明一个数组
        const west=["唐僧","孙悟空","猪八戒","沙僧"];
        //使用for……of遍历数组
        for(let v of west)
        {
            //for of遍历出来的是数组元素值
            console.log(v);
        }
        for(let v in west)
        {
            //for in遍历出来的是数组元素索引
            console.log(v);
        }

        //原型链上有["Symbol(Symbol.iterator)"]
        console.log(west);
        /*
        工作原理
        a）创建一个指针对象，指向当前数据结构的起始位置
        b）第一次调用对象的next方法，指针自动指向数据结构的第一个成员
        c）接下来不断调用next方法，指针一直往后移动，直到指向最后一个成员
        d）每调用next方法返回一个包含value和done属性的对象
        */

        let iterator=west[Symbol.iterator]();
        //调用对象的next方法
        for(var i=1;i<5;i++)
        {
            console.log(iterator.next().value);
        }
    </script>
</head>
<body>
    
</body>
</html>